# 數位系統設計作業-3 DW8051 – I2C Master

溫進坤 james wen@hotmail.com

## 作業題目

- 1. 設計一個DW8051的I2C MASTER IP 。
- 2. 在DW8051程式中透過I2C MASTER Register,將 EEPROM的位址0寫入0x12,位址1寫入0x34。
- 3. 使用M24AA256.v當I2C Slave EEPROM model。
- 4. Modelsim的文字輸出結果,不能有Error Message。
- 5. 使用同步式設計,只能使用clk\_50M或reset當 clock,不能使用其他輸入信號當clock使用。

## **Block Diagram**



# I2C Master Register Map

| SFR Addr | Description              | Note                                               |
|----------|--------------------------|----------------------------------------------------|
| Ox9A     | I2C Control Byte         | Bit0:Write<br>Bit1:Read<br>Bit4:Start<br>Bit5:Stop |
| 0x9B     | I2C Status Byte          | Bit0:Complete<br>Bit1:Error                        |
| 0x9C     | I2C Write/Read Data Byte | I2C write or read data                             |

## **AC CHARACTERISTICS**

| AC CHARACTERISTICS |         |                                   | Electrical Characteristics:<br>Industrial (I): Vcc = +1.7V to 5.5V TA = -40°C to +85°C<br>Automotive (E): Vcc = +1.7V to 5.5V TA = -40°C to +125°C |                           |       |                                                                                                  |  |
|--------------------|---------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------|--------------------------------------------------------------------------------------------------|--|
| Param.<br>No.      | Sym.    | Characteristic                    | Min.                                                                                                                                               | Max.                      | Units | Conditions                                                                                       |  |
| 1                  | FCLK    | Clock frequency                   | =                                                                                                                                                  | 100<br>400<br>400<br>1000 | kHz   | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256 |  |
| 2                  | THIGH   | Clock high time                   | 4000<br>600                                                                                                                                        | -                         | ns    | 1.7V ≤ Vcc < 2.5V                                                                                |  |
|                    |         | _                                 | 500<br>500                                                                                                                                         | =                         |       | 2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256                      |  |
| 3                  | TLOW    | Clock low time                    | 4700<br>1300<br>1300<br>500                                                                                                                        | Ξ                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256 |  |
| 4                  | TR      | SDA and SCL rise time<br>(Note 1) | Ξ                                                                                                                                                  | 1000<br>300<br>300        | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc ≤ 5.5V 24FC256                              |  |
| 5                  | TF      | SDA and SCL fall time<br>(Note 1) | _                                                                                                                                                  | 300<br>100                | ns    | All except, 24FC256<br>1.7V ≤ Vcc ≤ 5.5V 24FC256                                                 |  |
| 6                  | THD:STA | Start condition hold time         | 4000<br>600<br>600<br>250                                                                                                                          | =                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256 |  |
| 7                  | Tsu:sta | Start condition setup time        | 4700<br>600<br>600<br>250                                                                                                                          | =                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256 |  |
| 8                  | THD:DAT | Data input hold time              | 0                                                                                                                                                  | _ =                       | ns    | (Note 2)                                                                                         |  |
| 9                  | TSU:DAT | Data input setup time             | 250<br>100<br>100                                                                                                                                  | =                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc ≤ 5.5V 24FC256                              |  |
| 10                 | Tsu:sto | Stop condition setup time         | 4000<br>600<br>600<br>250                                                                                                                          | =                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256 |  |
| 11                 | TSU:WP  | WP setup time                     | 4000<br>600<br>600                                                                                                                                 | Ξ                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc ≤ 5.5V 24FC256                              |  |
| 12                 | THD:WP  | WP hold time                      | 4700<br>1300<br>1300                                                                                                                               | Ξ                         | ns    | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc ≤ 5.5V 24FC256                              |  |

## **AC CHARACTERISTICS**

| AC CHARACTERISTICS (Continued) |      | Electrical Characteristics:<br>Industrial (I):                                     |                             |                           |        |                                                                                                     |
|--------------------------------|------|------------------------------------------------------------------------------------|-----------------------------|---------------------------|--------|-----------------------------------------------------------------------------------------------------|
| Param.<br>No.                  | Sym. | Characteristic                                                                     | Min.                        | Max.                      | Units  | Conditions                                                                                          |
| 13                             | TAA  | Output valid from clock (Note 2)                                                   | =                           | 3500<br>900<br>900<br>400 | ns     | 1.7 V ≤ Vcc < 2.5V<br>2.5 V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5 V ≤ Vcc ≤ 5.5V 24FC256 |
| 14                             | TBUF | Bus free time: Time the bus<br>must be free before a new<br>transmission can start | 4700<br>1300<br>1300<br>500 | =                         | ns     | 1.7V ≤ Vcc < 2.5V<br>2.5V ≤ Vcc ≤ 5.5V<br>1.7V ≤ Vcc < 2.5V 24FC256<br>2.5V ≤ Vcc ≤ 5.5V 24FC256    |
| 15                             | TOF  | Output fall time from VIH<br>minimum to VIL maximum<br>C8 ≤ 100 pF                 | 10 + 0.1CB                  | 250<br>250                | ns     | All except, 24FC256 (Note 1)                                                                        |
| 16                             | TSP  | Input filter spike suppression (SDA and SCL pins)                                  | _                           | 50                        | ns     | All except, 24FC256 (Notes 1 and 3)                                                                 |
| 17                             | Twc  | Write cycle time (byte or page)                                                    | _                           | 5                         | ms     | _                                                                                                   |
| 18                             | ===  | Endurance                                                                          | 1,000,000                   | _                         | cycles | Page mode, 25°C, 5.5V (Note 4)                                                                      |

### **I2C BUS TIMING DATA**



### I2C DATA TRANSFER SEQUENCE ON THE SERIAL BUS



## **I2C Control Byte Format**



### 24AA256 ACKNOWLEDGE TIMING



## 24AA256 ADDRESS SEQUENCE BIT ASSIGNMENTS



#### 24AA256 BYTE WRITE



**Slave Response** 

#### **ACKNOWLEDGE POLLING FLOW**



### 文字輸出結果

```
Transcript

Slm:/hw4_tb/write_control \
sim:/hw4_tb/write_addr \
sim:/hw4_tb/write_value \
sim:/hw4_tb/i2c_sda \
sim:/hw4_tb/i2c_scl

VSIM 6> run -all

# time= 0 memory_000=0xxx memory_001=0xxx
# time=1002030 control=0xa0 addr=0x0000 data=0x12
# time=6382471 memory_000=0x12 memory_001=0xxx
# time=7004030 control=0xa0 addr=0x0001 data=0x34
# time=12384471 memory_000=0x12 memory_001=0x34
# time=12384471 memory_000=0x12 memory_001=0x34
# time=12384471 memory_000=0x12 memory_01=0x34
# time=12384471 memory_000=0x12 memory_001=0x34
```

## 計分方式

- 1. 將全部Verilog程式及modelsim模擬結果、波形截 圖壓縮成ZIP檔,上傳至Moodle[繳交作業],並在 檔名依序寫上學號、作業號。
- 2. 上傳檔案名稱:學號\_HW3. zip
- 3. 計分標準依完成順序及程式內容給分,<u>若發現程</u> 式或輸出畫面結果有複製狀況,該員此次作業分 數為0分。